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© Method and apparatus for finding areas of interest in images. 



© An apparatus, and corresponding method for 
finding an area of interest in an input image, filters 
the input image with at least one compression filter 
(106) to generate a final compressed image. The 
apparatus determines the location of an artifact in 
the final compressed image and then determines the 
location of the area of interest in the input image 
according to the location of the artifact in the final 
compressed image. 

An apparatus, and corresponding method for 



finding one or more artifacts in a two-dimensional 
image, receives a first row of the image and gen- 
erates a list of regions in accordance with the first 
row. The apparatus receives a next row of the image 
and updates the list of regions in accordance with 
the next row. The apparatus determines whether a 
region in the list of regions corresponds to an artifact 
in the image and, if so, selects the region as the 
artifact. 
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BACKGROUND OF THE INVENTION 

Field of the Invention 

The present invention relates to finding areas 5 
of interest in images, and to methods and ap- 
paratuses for finding areas or regions of interest in 
two-dimensional gray-scale images. More particu- 
larly, the present invention relates to methods and 
apparatuses for finding barcode symbols in static 10 
or dynamically evolving two-dimensional gray-scale 
images. 

Statement of Related Art 

75 

In the field of package shipping, barcode sym- 
bols encode information about packages. One or 
more of these barcode symbols are printed on 
shipping labels that are affixed to packages. These 
barcode symbols may then be "read" using label 20 
reading systems. In some applications, packages 
are required to be processed in real time under 
conditions that are not well suited for conventional 
laser-based label reading systems. Such applica- 
tions require large depths and fields of view as well 25 
as the ability to process randomly oriented labels. 
For example, a fixed barcode scanner positioned 
above a moving conveyor belt may be required to 
find and decode barcode symbols on labels affixed 
to packages that pass under the scanner. These 30 
barcode symbols may be randomly oriented and 
positioned within the scanner's field of view at 
various distances from the scanner. When em- 
ployed in connection with such applications, con- 
ventional laser-based label reading systems may 35 
not have sufficient depth and field of view. 

SUMMARY OF THE INVENTION 

The present invention is a method and appara- 40 
tus for finding an area of interest in an input image. 
The input image is filtered with at least one com- 
pression filter to generate a final compressed im- 
age. The location of an artifact in the final com- 
pressed image is determined, and then the location 45 
of the area of interest in the input image is deter- 
mined according to the location of the artifact in the 
final compressed image. 

In a preferred embodiment, the present inven- 
tion comprises a method and apparatus for finding so 
one or more artifacts in a two-dimensional image. A 
first row of the image is received and a list of 
regions is generated in accordance with the first 
row. The apparatus receives a next row of the 
image and updates the list of regions in accor- 55 
dance with the next row. The apparatus determines 
whether a region in the list of regions corresponds 
to an artifact in the image and, if so, selects the 



region as the artifact. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 presents a block diagram of a barcode 
symbol location system for finding barcode 
symbols in two-dimensional gray-scale input im- 
ages according to a preferred embodiment of 
the present invention; 

Fig. 2 presents a block diagram of the VICKey 
card of the location system of Fig. 1; 
Fig. 3 presents a block diagram of a circuit that 
is a preferred partial snapshot embodiment of 
the compression control logic and the working 
memory of the VICKey card of the location 
system of Fig. 1; 

Fig. 4 presents a block diagram of a circuit that 
is a preferred pipeline embodiment of the com- 
pression control logic and the working memory 
of the VICKey card of the location system of 
Fig. 1; 

Fig. 5 presents a timing table showing the pro- 
cessing activities performed by the filters and 
buffers that implement the (4x4) MIN compres- 
sion filter of the preferred sequence of compres- 
sion filters implemented by the circuit of Fig. 4; 
Fig. 6 presents a timing table showing the pro- 
cessing activities performed by the filters and 
buffers that implement the first (2x2) MIN com- 
pression filter of the preferred sequence of com- 
pression filters implemented by the circuit of 
Fig. 4; 

Fig. 7 presents a timing table showing the pro- 
cessing activities performed by the filters and 
buffers that implement the second (2x2) MIN 
compression filter of the preferred sequence of 
compression filters implemented by the circuit 
of Fig. 4; 

Fig. 8 presents a timing table showing the pro- 
cessing activities performed by the filters and 
buffers that implement the (2x2) MAX compres- 
sion filter of the preferred sequence of compres- 
sion filters implemented by the circuit of Fig. 4; 
Fig. 9 presents a (512x512) 8-bit gray-scale 
input image containing a barcode symbol; 
Fig. 10 presents the (512x512) binary threshol- 
ded image generated by thresholding Fig. 9 at 
an intensity level of 70; 

Fig. 11 presents the (128x128) binary com- 
pressed image generated by applying a (4x4) 
MIN compression filter to the thresholded image 
of Fig. 10; 

Fig. 12 presents the (64x64) binary compressed 
image generated by applying a (2x2) MIN com- 
pression filter to the compressed image of Fig. 
11; 

Fig. 13 presents the (32x32) binary compressed 
image generated by applying a (2x2) MIN com- 
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pression filter to the compressed image of Fig. 
12; 

Fig. 14 presents the (16x16) binary compressed 
image generated by applying a (2x2) MAX com- 
pression filter to the compressed image of Fig. 
13; and 

Fig. 15 presents a process flow diagram of a 
sub-image identification subsystem for identify- 
ing sub-images in input images that may contain 
barcode symbols according to the location sys- 
tem of Fig. 1. 

DETAILED DESCRIPTION OF THE INVENTION 

The present invention processes input images 
to select one or more sub-images that may contain 
areas of interest such as barcode symbols. Bar- 
code symbol detection and decoding algorithms 
are then applied only to the smaller sub-images, 
thereby dramatically reducing the overall time re- 
quired to detect and decode barcode symbols. 
Thus, the present invention enables a label reading 
system to locate and decode barcode symbols 
printed on shipping labels at the high rates re- 
quired in the field of package shipping. 

The system of the present invention for finding 
an area of interest in an input image begins by 
compressing the input image with one or more 
filters to generate a binary final compressed image. 
At least one of the filters is a compression filter. 
One of the filters may also be a thresholding filter. 
The system determines the location of artifacts in 
the final compressed image, and then, using those 
locations, identifies sub-images of the input image 
that correspond to the artifacts. An artifact is an 
region in the final compressed image that repre- 
sents an area of interest, such as a barcode sym- 
bol, in the input image. 

Fig. 1 presents a block diagram of a preferred 
embodiment of a barcode symbol location system 
100 for finding areas of interest in two-dimensional 
gray-scale input images according to the present 
invention. The areas of interest may be barcode 
symbols, which comprise sequences of black bars 
and white spaces. The black bars of barcode sym- 
bols are represented in the input images by dark 
pixels typically having relatively low intensity lev- 
els, and white spaces are represented by bright 
pixels typically having relatively high intensity lev- 
els. The barcode symbols may have random and 
unknown locations and orientations in the input 
images. 

Location system 100 applies thresholding and 
compression filters to a gray-scale input image 
containing one or more barcode symbols to create 
a binary final compressed image in which each 
barcode symbol in the input image is represented 
by one isolated, contiguous black region in the final 



compressed image, and each isolated, contiguous 
black region in the final compressed image repre- 
sents at most one barcode symbol in the input 
image. In the binary final compressed image, white 
s pixels have a value of "1" and black pixels have a 
value of "0". A black region in the final com- 
pressed image is a set of one or more black pixels. 

A black region is contiguous if every black 
pixel in the set is "connected" to at least one other 

w black pixel in the set. In a preferred embodiment, 
"connected" is defined in terms of four-way con- 
nectivity. That is, two pixels are connected, if they 
have a common side. A contiguous black region 
may have "holes," that is, one or more white pixels 

75 in the interior of the region. Two contiguous black 
regions are isolated if none of their black pixels are 
connected to black pixels in the other region. Thus, 
location system 100 transforms a gray-scale input 
image into a binary final compressed image in 

20 which each barcode symbol in the input image is 
represented by a set of black pixels in the final 
compressed image that are connected to each 
other, but are not connected to black pixels that 
represent a different barcode symbol in the input 

25 image. 

Location system 100 characterizes all of the 
black regions in the final compressed image. If a 
black region meets specific geometry requirements 
dictated by the size and shape of an expected 

30 barcode symbol, then the region may represent a 
barcode symbol. Such a region is selected to re- 
present a "candidate" barcode symbol. Location 
system 100 then determines the coordinates of a 
sub-image in the input image that corresponds to 

35 each selected region in the final compressed im- 
age. A decoding subsystem may then efficiently 
process each sub-image to determine whether 
each candidate barcode symbol is a true barcode 
symbol, and, if so, decode it. Areas of interest 

40 other than barcode symbols may also be repre- 
sented in the final compressed image as isolated, 
contiguous black regions. 

Location system 100 includes camera 102, 
which is preferably a CCD camera that generates 

45 in serial output format analog pixel signals cor- 
responding to two-dimensional analog images with 
a pixel resolution of less than 100 pixels per inch. 
Camera 102 may comprise either a line-type or 
array-type CCD chip, such as a 4096-pixel Linear 

so Image Sensor Array (Model IL-C5-4096 "TUR- 
BOSENSOR") manufactured by DALSA Inc. of 
Waterloo, Ontario, Canada, or a 4096-pixel linear 
CCD Image Sensor (Model TH7833) manufactured 
by Thomson. Camera 102 may be used to gen- 

55 erate analog images containing representations of 
package labels or other surfaces displaying bar- 
code symbols. Camera 102 transmits the analog 
pixel signals of the analog images to analog-to- 
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digital converter 104. 

In alternative preferred embodiments, a loca- 
tion system according to the present invention may 
be designed to locate areas of interest other than 
barcode symbols. For example, a location system 
may be designed to locate areas of interest repre- 
sentative of other symbologies such as "UP- 
SCODE", "VERICODE", "DATA CODE", and 
"PDF417", as well as other one- and two-dimen- 
sional symbologies. "UPSCODE" is a registered 
trademark of United Parcel Service of America, Inc. 
Details of the "UPSCODE" symbology are dis- 
closed in U.S. Patent Nos. 4,874,936, 4,896,029, 
and 4,998,010, which are hereby incorporated 
herein in their entirety by reference. Details of the 
"VERICODE" and "DATA CODE" symbologies are 
disclosed in U.S. Patent Nos. 4,924,078 and 
4,939,154, which are hereby incorporated herein in 
their entirety by reference. In addition, location 
systems within the scope of the present invention 
may be designed to locate areas of interest such 
as individual characters, or sets of characters such 
as individual words or paragraphs, in input images. 
Depending on the application, a location system of 
the present invention may include a CCD-array 
camera with a resolution greater than or smaller 
than 100 pixels per inch. 

Anatog-to-digital converter 104 of location sys- 
tem 100 receives the analog pixel signals of an 
analog image from camera 102 and digitizes them 
into 8-bit pixels of a two-dimensional gray-scale 
input image. A/D converter 104 then applies a 
thresholding filter to threshold each 8-bit pixel of 
the input image into a binary pixel of a first 
thresholded image. In a preferred embodiment, A/D 
converter 104 applies an adaptive thresholding fil- 
ter to generate the binary pixels of the first 
thresholded image. In an alternative preferred em- 
bodiment, A/D converter 104 applies a multipole 
analog filter to generate these binary pixels. A/D 
converter 104 transmits both the 8-bit pixels of the 
input image and the binary pixels of the first 
thresholded image to VICKey card 106. In a pre- 
ferred embodiment, in each processor cycle, A/D 
converter 104 transmits to VICKey card 106 a pair 
of adjacent 8-bit pixels from the input image and 
the two corresponding binary pixels from the first 
thresholded image. 

VICKey card 106 is preferably a digital logic 
board with buffer memory. VICKey is an acronym 
for "VSB Interface Controller Key," where VSB 
stands for VME Subsystem Bus. VICKey card 106 
performs data conversion, manipulation, reformat- 
ting, and transfer to provide interfacing of input with 
output. VICKey card 106 also applies a threshol- 
ding filter to convert each 8-bit pixel of the input 
image into a binary pixel of a second thresholded 
image. As described in greater detail later in this 



specification in conjunction with Fig. 2, a system 
CPU command determines whether the first 
thresholded image or the second thresholded im- 
age is selected for further processing. VICKey card 

s 106 applies a sequence of compression filters to 
the selected thresholded image to generate a final 
compressed image. The thresholding and com- 
pression filters transform an input image having 
barcode symbols or other areas of interest into a 

ro final compressed image having isolated, contiguous 
black regions, where each barcode symbol or other 
area of interest in the input image is represented 
by a different isolated, contiguous black region in 
the final compressed image. VICKey card 106 out- 

15 puts the gray-scale input image and the final com- 
pressed image to a VSB Bus. Processor 108 reads 
the final compressed image and processor 110 
reads the gray-scale input image from the VSB 
Bus. 

20 Processor 108 is a reduced instruction set 

computer (RISC) processor that implements soft- 
ware for determining the location of artifacts in the 
final compressed image. The artifacts are isolated, 
contiguous black regions in the final compressed 

25 image that meet specific geometry requirements 
and may therefore represent barcode symbols or 
other areas of interest in the input image. Proces- 
sor 108 is preferably a "SUPERCARD2" brand 
i860 CPU RISC processor, manufactured by Com- 

30 puter Signal Processors, Inc. (CSPI). 

Processor 108 receives the final compressed 
image from VICKey card 106, determines the loca- 
tions of the compressed barcode symbols or other 
areas of interest in the final compressed image, 

35 and then uses those locations to determine the 
coordinates of sub-images in the input image that 
contain candidate barcode symbols or other can- 
didate areas of interest. The sub-image coordinates 
are then transmitted to processor 110. The coordi- 

40 nates of a sub-image in the input image are prefer- 
ably represented by the two rows and two columns 
that form the boundary of the sub-image. For ex- 
ample, in a (512x512) input image, rows 20 and 80 
and columns 100 and 180 may represent the rec- 

45 tangular (61x81) sub-image in the input image 
bounded by rows 20 and 80 and columns 100 and 
180. 

Processor 110 is a RISC processor that imple- 
ments software for identifying and decoding the 

so candidate barcode symbols contained in the sub- 
images of the input image selected by processor 
108. Like processor 108, processor 110 is prefer- 
ably a "SUPERCARD2" brand i860 CPU RISC 
processor, manufactured by CSPI. Processor 110 

55 receives from processor 108 the coordinates for 
the sub-images in the input image that contain 
candidate barcode symbols, processes each sub- 
image to identify the true barcode symbols, de- 
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codes the barcode symbols, and transmits the de- 
coded barcode symbol data to system CPU 112. 
Processor 110 is preferably implemented by the 
barcode detector and decoder described in the 
U.S. patent application entitled "Method and Ap- 
paratus for Detecting and Decoding Barcode Sym- 
bols," filed August 10, 1992, invented by Luis 
Figarella and Mihael Klancnik, in the U.S. patent 
application entitled "Method and Apparatus for De- 
coding Barcode Symbols Using Subpixel Interpola- 
tion," filed August 10, 1992, invented by Mihael 
Klancnik and Luis Figarella, and in the U.S. patent 
application entitled "Method and Apparatus for De- 
tecting Artifact Corners in Two-Dimensional Im- 
ages," filed August 10, 1992, invented by Joe 
Zheng and Mihael Klancnik, which are all assigned 
to the assignee of the present application and the 
contents of which are all incorporated herein by 
reference. System CPU 112 controls the operations 
of location system 100 and interfaces with in- 
put/output card 114, which provides a user inter- 
face. 

Detailed Description of VICKey Card 

Fig. 2 presents a block diagram of VICKey 
card 106 of location system 100 according to a 
preferred embodiment of the present invention. 
Command register 214 receives from system CPU 
112 the command and control signals that control 
the operations of VICKey card 106. Command reg- 
ister 214 transmits the appropriate commands and 
control signals to input buffer 202, compression 
control logic 208, and output control/driver 206. 
These commands and control signals will be ex- 
plained in greater detail later in this section in 
conjunction with descriptions of these system com- 
ponents. 

In each processor cycle, input buffer 202 of 
VICKey card 106 receives from A/D convertor 104 
a pair of adjacent 8-bit pixels from the input image 
and the two corresponding binary pixels from the 
first thresholded image. Input buffer 202 transmits 
the two 8-bit pixels to data buffer 204, which accu- 
mulates and eventually transmits the 8-bit pixels to 
output control/driver 206. Output control/driver 206 
then transmits the 8-bit pixels to processor 110. 

Input buffer 202 thresholds each pair of 8-bit 
pixels to create a pair of binary pixels using a 
threshold specified by a command from system 
CPU 112 and directed to input buffer 202 by com- 
mand register 214. These binary pixels correspond 
to the second thresholded image. Another system 
CPU command determines whether the first or the 
second thresholded image is to be selected for 
further processing. Input buffer 202 transmits to 
compression control logic 208 the two binary pixels 
corresponding to whichever thresholded image is 



selected. 

Compression control logic 208 applies a se- 
quence of compression filters to the selected 
thresholded image to create a final compressed 

5 image. In a preferred embodiment, compression 
control logic 208 can apply a sequence of either 
three or four filters. The fourth filter is an optional 
filter that may be activated or inactivated by a 
system-CPU command directed from system CPU 

w 112 to compression control logic 208 by command 
register 214. The first filter in the sequence is a 
(4x4) compression filter that reduces each non- 
overlapping (4x4) pixel area of the selected 
thresholded image to a single binary pixel of a first 

is compressed image. 

The second filter in the sequence is a first 
(2x2) compression filter that reduces each non- 
overlapping (2x2) pixel area of the first compressed 
image to a single binary pixel of a second com- 

20 pressed image. The third filter in the sequence is a 
second (2x2) compression filter that reduces each 
non-overlapping (2x2) pixel area of the second 
compressed image to a single binary pixel of a 
third compressed image. The fourth filter in the 

25 sequence is a third (2x2) compression filter that 
reduces each non-overlapping (2x2) pixel area of 
the third compressed image to a single binary pixel 
of a fourth compressed image. 

When all four filters are activated, the final 

30 compressed image is the fourth compressed image 
and the numbers of rows and columns in the, 
selected thresholded image are both reduced by a 
compression ratio of 32. That is, an input image 
that has 2048 rows of 8-bit pixels with 4096 pix- 

35 els/row is compressed into a (64x128) final com- 
pressed image comprised of binary pixels. When 
the last filter is deactivated, the final compressed 
image is the third compressed image and the com- 
pression ratio is 16 in each direction. 

40 In addition to being able to activate or deacti- 
vate the fourth filter, each filter may be indepen- 
dently selected to be either a MAX filter or a MIN 
filter based on system-CPU commands directed 
from system CPU 112 to compression control logic 

45 208 by command register 214. A MAX filter applies 
an "OR" function to replace the binary pixels of a 
selected pixel area with a single 1-bit result cor- 
responding to a binary pixel, where a white pixel is 
represented by a "1 ", and a black pixel, by a "0". 

50 In other words, if any binary pixel in the pixel area 
is "1" (white), the result of a MAX filter is a "1". If 
all of the binary pixels in the pixel area are "0" 
(black), then the result of a MAX filter is a "0". 
Similarly, a MIN filter applies an "AND" function to 

55 each pixel area. A MIN filter generates a "1 " only if 
all binary pixels in the pixel area are white; other- 
wise, a MIN filter generates a "0". 
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In a preferred embodiment, the fourth filter is 
activated and compression control logic 208 ap- 
plies a sequence of four filters where the first filter 
is a (4x4) MIN filter, the second and third filters are 
(2x2) MIN filters, and the fourth filter is a (2x2) 
MAX filter. This sequence was selected empirically 
using test input images that are similar to input 
images containing barcode symbols to be located 
in a particular application. 

Those skilled in the art will understand that, in 
alternative embodiments of the present invention, 
compression control logic 208 may apply alter- 
native sequences of filters. These alternative se- 
quences may include different numbers of filters, 
different sizes of filters, and different types of fil- 
ters. MIN and MAX filters are particular types of 
voting scheme filters. Alternative embodiments of 
the present invention may employ voting scheme 
filters other than MIN and MAX filters. In an alter- 
native preferred embodiment, compression control 
logic 208 applies more robust filtering that may 
include nearest neighbor influences. Moreover, not 
all filters in the sequence need to be compression 
filters. The selection of the sequence of filters to 
use for a particular application (e.g., to locate areas 
of interest corresponding to barcode, "UPSCODE", 
"VERICODE", "DATA CODE", or "PDF417" sym- 
bologies) may be made empirically by performing 
off-line analysis in which different filters and dif- 
ferent sequences of filters are applied to test input 
images representative of input images expected in 
the particular application. 

The preferred filtering sequence described 
above is selected to produce artifacts in a final 
compressed image, where each barcode symbol in 
the input image is represented by a single artifact 
in the final compressed image and each artifact 
represents only one candidate barcode symbol. 
That is, the thresholding and compression filtering 
preferably "grows" the individual black bars of a 
barcode symbol into a single black region in the 
final compressed image, while keeping the com- 
pressed barcode symbol isolated from other arti- 
facts that may represent other barcode symbols or 
other areas of interest in the input image. A "com- 
pressed barcode symbol" is a set of binary pixels 
in a compressed image that represents a particular 
barcode symbol in the input image used to gen- 
erate the compressed image. Those skilled in the 
art will understand that it is acceptable to include, 
in the compressed barcode symbol, compressed 
representations of the alphanumeric characters that 
are typically displayed immediately below some 
barcode symbols. 

In a preferred pipeline embodiment, compres- 
sion control logic 208 begins to apply the selected 
sequence of compression filters as soon as it re- 
ceives from input buffer 202 the first pair of binary 



pixels in the first row of the selected thresholded 
image. Each compression filter operates on either 
(4x4) or (2x2) pixel areas. Compression control 
logic 208 begins applying these two-dimensional 

s filters before the entire pixel areas to which the 
filters are applied are received or generated. Com- 
pression control logic 208 then transmits partial 
results from the compression filters to working 
memory 210. Working memory 210 stores the par- 

w tial results until compression control logic 208 ac- 
cesses them for the on-going sequence of com- 
pression filtering. Compression control logic 208 
also transmits a serial stream of binary pixels cor- 
responding to the final compressed image to out- 

75 put buffer 212. This preferred pipeline embodiment 
is described in further detail later in this specifica- 
tion in conjunction with Fig. 4. 

Output buffer 212 receives the serial stream of 
binary pixels from compression control logic 208, 

20 reformats that data into a parallel stream, and 
transmits the parallel data to output control/driver 
206. Output control/driver 206 transmits the binary 
pixels of the final compressed image to processor 
108. 

25 

Preferred Snapshot Embodiment 

In alternative preferred embodiments, location 
system 100 processes input images using different 

30 procedures. These embodiments include a snap- 
shot embodiment, a partial snapshot embodiment, 
and a pipeline embodiment. In a preferred snap- 
shot embodiment, location system 100 generates 
an entire input image and then processes the input 

35 image by applying each two-dimensional compres- 
sion filter to an entire image. A snapshot embodi- 
ment may be useful in situations in which single 
images are to be processed, and storage space 
and processing time are amply available. 

40 An exemplary input image having 2048 rows of 
4096 pixels/row is used to facilitate the description 
of a snapshot embodiment. Location system 100 
generates a (2048x4096) selected thresholded im- 
age from the (2048x4096) input image. After the 

45 selected thresholded image is completely gener- 
ated, location system 100 then applies a (4x4) MIN 
compression filter to each non-overlapping (4x4) 
pixel area of the selected thresholded image to 
generate a (512x1024) first compressed image. 

so After the first compressed image is completely 
generated, location system 100 then applies a first 
(2x2) MIN compression filter to each non-overlap- 
ping (2x2) pixel area of the first compressed image 
to generate a (256x512) second compressed im- 

55 age. After the second compressed image is com- 
pletely generated, location system 100 then applies 
a second (2x2) MIN compression filter to each non- 
overlapping (2x2) pixel area of the second com- 
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pressed image to generate a (128x256) third com- 
pressed image. After the third compressed image 
is completely generated, location system 100 then 
applies a (2x2) MAX compression filter to each 
non-overlapping (2x2) pixel area of the third com- 
pressed image to generate a (64x128) fourth and 
final compressed image. The complete final com- 
pressed image may then be analyzed to locate 
candidate barcode symbols for eventually iden- 
tification and decoding. 

Preferred Partial Snapshot Embodiment 

In a preferred partial snapshot embodiment, 
location system 100 accumulates partial snapshots 
of images and applies each two-dimensional com- 
pression filter to pixel areas of those partial snap- 
shots. In this embodiment, after each (4x4096) sub- 
image of a (2048x4096) selected thresholded im- 
age is generated, location system 100 applies a 
(4x4) MIN compression filter to each non-overlap- 
ping (4x4) pixel area of the (4x4096) sub-image to 
generate a single row of a (512x1024) first com- 
pressed image. After each (2x1024) sub-image of 
the first compressed image is generated, location 
system 100 applies a first (2x2) MIN compression 
filter to each non-overlapping (2x2) pixel area of the 
(2x1024) sub-image to generate a single row of a 
(256x512) second compressed image. After each 
(2x512) sub-image of the second compressed im- 
age is generated, location system 100 applies a 
second (2x2) MIN compression filter to each non- 
overlapping (2x2) pixel area of the (2x512) sub- 
image to generate a single row of a (128x256) third 
compressed image. After each (2x256) sub-image 
of the third compressed image is generated, loca- 
tion system 100 applies a (2x2) MAX compression 
filter to each non-overlapping (2x2) pixel area of the 
(2x256) sub-image to generate a single row of a 
(64x128) fourth and final compressed image. 

Fig. 3 presents a block diagram of circuit 300, 
which is a preferred partial snapshot embodiment 
of compression control logic 208 and working 
memory 210 of VICKey card 106. To facilitate the 
description of circuit 300 of Fig. 3, the example of 
a (2048x4096) selected thresholded image from the 
discussion of the snapshot embodiment of the pre- 
vious section is used. In each processor cycle, 4- 
line accumulator 302 receives from input buffer 202 
of VICKey card 106 a pair of adjacent binary pixels 
from the selected thresholded image. Accumulator 
302 accumulates those binary pixels until four rows 
of the selected thresholded image are received, at 
which time, accumulator 302 transmits all four rows 
to (4x4) filter 304. Accumulator 302 then begins to 
accumulate binary pixels from the next four rows of 
the selected thresholded image for similar subse- 
quent transmission to filter 304. 



The four rows received by (4x4) filter 304 from 
accumulator 302 correspond to a (4x4096) pixel 
area of the selected thresholded image. Filter 304 
applies a (4x4) compression filter to each of the 
5 1024 non-overlapping (4x4) pixel areas of the 
(4x4096) pixel area. Filter 304 is preferably se- 
lected to be a MIN filter. Filter 304 compresses 
each (4x4096) pixel area of the selected threshol- 
ded image into a (1x1024) row of a first com- 

io pressed image. Filter 304 transmits the (1x1024) 
row serially to 2-line accumulator 306. Filter 304 
effectively compresses the (2048x4096) selected 
thresholded image to a (512x1024) first com- 
pressed image. 

75 2-line accumulator 306 receives binary pixels 
from (4x4) filter 304 until two rows of the first 
compressed image are accumulated, at which time, 
accumulator 306 transmits the two rows to (2x2) 
filter 308. The two rows received by (2x2) filter 308 

20 from accumulator 306 correspond to a (2x1024) 
pixel area of the first compressed image generated 
by filter 304. Filter 308 applies a (2x2) compression 
filter to each of the 512 non-overlapping (2x2) pixel 
areas of the (2x1024) pixel area. Filter 308 is pref- 

25 erably selected to be a MIN filter. Filter 308 com- 
presses each (2x1024) pixel area of the first com- 
pressed image into a (1x512) row of a second 
compressed image. Filter 308 transmits the (1x512) 
row serially to 2-line accumulator 310. Filter 308 

30 effectively compresses the (512x1024) first com- 
pressed image generated by filter 304 to a 
(256x512) second compressed image. 

2-line accumulator 310 receives binary pixels 
from (2x2) filter 308 until two rows of the second 

35 compressed image are accumulated, at which time, 
accumulator 310 transmits the two rows to (2x2) 
filter 312. The two rows received by (2x2) filter 312 
from accumulator 310 correspond to a (2x512) 
pixel area of the second compressed image gen- 

40 erated by filter 308. Filter 312 applies a (2x2) 
compression filter to each of the 256 non-overlap- 
ping (2x2) pixel areas of the (2x512) pixel area. 
Filter 312 is preferably selected to be a MIN filter. 
Filter 312 compresses each (2x512) pixel area of 

45 the second compressed image into a (1x256) row 
of a third compressed image. Filter 312 transmits 
the (1x256) row serially to 2-line accumulator 314 
and to compression selection multiplexer 318. Filter 
312 effectively compresses the (256x512) second 

so compressed image generated by filter 308 to a 
(128x256) third compressed image. 

2-line accumulator 314 receives binary pixels 
from (2x2) filter 312 until two rows of the third 
compressed image are accumulated, at which time, 

55 accumulator 314 transmits the two rows to (2x2) 
filter 316. The two rows received by (2x2) filter 316 
from accumulator 314 correspond to a (2x256) 
pixel area of the third compressed image gen- 
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erated by filter 312. Filter 316 applies a (2x2) 
compression filter to each of the 128 non-overlap- 
ping (2x2) pixel areas of the (2x256) pixel area. 
Filter 316 is preferably selected to be a MAX filter. 
Filter 316 compresses each (2x256) pixel area of 
the third compressed image into a (1x128) row of a 
fourth compressed image. Filter 316 transmits the 
(1x128) row serially to compression selection mul- 
tiplexer 318. Filter 312 effectively compresses the 
(128x256) third compressed image generated by 
filter 312 to a (64x128) fourth compressed image. 

If (2x2) filter 316, the fourth compression filter, 
is activated, then compression selection multiplexer 
318 transmits to output buffer 212 binary pixels 
from filter 316 that correspond to the (64x128) 
fourth compressed image. Otherwise, multiplexer 
318 transmits to output buffer 212 binary pixels 
from filter 312 corresponding to the (128x256) third 
compressed image. Filter 316 is preferably ac- 
tivated. The binary pixels transmitted by multi- 
plexer 318 to output buffer 212 correspond to the 
final compressed image. 

Preferred Pipeline Embodiment 

In a preferred pipeline embodiment, location 
system 100 finds barcode symbols by processing 
input images in a pipelined manner, in which one 
pair of adjacent pixels is processed in each proces- 
sor cycle. In one preferred pipeline embodiment, 
location system 100 operates at 20 MHz with a 
processor cycle period of 50 nanoseconds. In this 
embodiment, VICKey card 106 begins to apply the 
sequence of compression filters before the com- 
plete pixel areas on which the compression filters 
operate are received from A/D convertor 104. 

In this preferred pipeline embodiment, camera 
102 may be a video camera that generates a 
continuous stream of images that may collectively 
be considered to be one continuous image. When 
camera 102 is positioned above a moving conveyor 
belt, location system 100 may be operated in a 
continuous mode to find barcode symbols in this 
one continuous image. In this embodiment, pixel 
columns in the input image are aligned with the 
direction of motion of the conveyor belt with the 
bottom row of one input image followed by the top 
row of the next input image. 

Fig. 4 presents a block diagram of circuit 400, 
which is a preferred pipeline embodiment of com- 
pression control logic 208 and working memory 
210. In this embodiment, location system 100 pro- 
cesses input images in a pipelined manner, where 
compression control logic 208 begins applying a 
selected sequence of compression filters as soon 
as a pair of adjacent binary pixels from the se- 
lected thresholded image is received from input 
buffer 202 of VICKey card 106. In this preferred 



embodiment with a processor cycle period of 50 
nanoseconds, A/D convertor 104 transmits data to 
input buffer 202 at a rate of 20 megabytes per 
second. 

5 Circuit 300 of Fig. 3 and circuit 400 of Fig. 4 

are alternative preferred embodiments of compres- 
sion control logic 208 and working memory 210 of 
VICKey card 106. Each circuit implements the pre- 
ferred sequence of four compression filters. Acting 

w together, filters 402, 406, and 410 of circuit 400 
implement the same (4x4) MIN filter implemented 
by filter 304 of circuit 300. Buffers 404 and 408 
temporarily store the results from filters 402 and 
406, respectively. Similarly, filters 412 and 416 of 

75 circuit 400 act together to implement the first (2x2) 
MIN filter as implemented by filter 308 of circuit 
300. Buffer 414 temporarily stores the results from 
filter 412. Filters 418 and 422 of circuit 400 to- 
gether implement the second (2x2) MIN filter as 

20 implemented by filter 312 of circuit 300. Buffer 420 
temporarily stores the results from filter 418. And 
lastly, filters 424 and 428 of circuit 400 act together 
to implement the (2x2) MAX filter implemented by 
filter 316 of circuit 300. Buffer 426 temporarily 

25 stores the results from filter 424. 

Continuing with the example from the discus- 
sion of Fig. 3, a (2048x4096) selected thresholded 
image may be considered to comprise 512 
(4x4096) 4-row pixel areas. As each row of the 4- 

30 row pixel areas is transmitted one after the other, 
two binary pixels at a time, from input buffer 202 to 
filter 402, circuit 400 processes the rows of the 4- 
row pixel areas. As circuit 400 processes a given 
row, each of the filters and buffers of circuit 400 is 

35 either inactive or performing specific functions. 

Fig. 5 presents a timing table showing the 
processing activities performed by filters 402, 406, 
and 410 and buffers 404 and 408 during four time 
periods. The first time period, identified as "Row 

40 1," corresponds to the time period during which 
the first row of a (4x4096) 4-row pixel area of a 
selected thresholded image is received by filter 
402 from input buffer 202. The second time period, 
identified as "Row 2," follows immediately after the 

45 "Row 1 " time period and corresponds to the time 
period during which the second row of the (4x4096) 
4-row pixel area is received by filter 402 from input 
buffer 202. 

Similarly, the third and fourth time periods, 
so identified as "Row 3" and "Row 4," respectively, 
correspond to the time periods during which the 
third and fourth rows of the (4x4096) 4-row pixel 
area are received by filter 402 from input buffer 
202. These four time periods repeat for each suc- 
55 cessive (4x4096) 4-row pixel area of the selected 
thresholded image. Where each row comprises 
4096 binary pixels and where two binary pixels are 
transmitted from input buffer 202 to filter 402 every 
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processor cycle, the "Row 1," "Row 2," "Row 3," 
and "Row 4" time periods are each 2048 processor 
cycles long. 

In each processor cycle, (1x4) filter 402 re- 
ceives from input buffer 202 a pair of adjacent 
binary pixels from the selected thresholded image. 
Filter 402 accumulates binary pixels for two pro- 
cessor cycles until four adjacent binary pixels are 
received. Since the (4x4) compression filter is pref- 
erably a MIN filter, filter 402 applies an "AND" 
function to the four binary pixels. Thus, if all four 
binary pixels are "1" (white), filter 402 generates a 
1-bit result of "1"; otherwise, filter 402 generates a 
1-bit result of "0". Filter 402 transmits a 1-bit result 
corresponding to four adjacent binary pixels every 
two processor cycles. 

Filters 402, 406, and 410 and buffers 404 and 
408 implement a (4x4) MIN compression filter on 
the (2048x4096) selected thresholded image. Dur- 
ing the "Row 1" time period, filter 402 transmits 1- 
bit results corresponding to the first row of a 
(4x4096) 4-row pixel area of a selected thresholded 
image to (1x4) buffer 404. During the "Row 2" time 
period, filter 402 transmits 1-bit results correspond- 
ing to the second row of the 4-row pixel area to 
(2x4) filter 406. During the "Row 3" time period, 
filter 402 transmits 1-bit results corresponding to 
the third row to buffer 404. And during the "Row 4" 
time period, filter 402 transmits 1-bit results cor- 
responding to the fourth row to (4x4) filter 410. 

During the "Row 1" time period, (1x4) buffer 
404 receives 1-bit results corresponding to the first 
row of a (4x4096) 4-row pixel area of a selected 
thresholded image from (1x4) filter 402. Since filter 
402 processes an entire row of binary pixels of the 
selected thresholded image before processing the 
next row, buffer 404 receives 1-bit results cor- 
responding to an entire row of the selected 
thresholded image from filter 402. Every 1-bit result 
received by buffer 404 corresponds to four adja- 
cent binary pixels in a row of the selected threshol- 
ded image. Where each row of the selected 
thresholded image has 4096 binary pixels, buffer 
404 stores 1024 1-bit results. 

During the "Row 2" time period, buffer 404 
transmits to (2x4) filter 406 the 1024 stored 1-bit 
results corresponding to the first row at a rate of 
one bit every two processor cycles. During the 
"Row 3" time period, buffer 404 receives 1024 1- 
bit results corresponding to the third row from (1x4) 
filter 402. During the "Row 4" time period, buffer 
404 transmits to (4x4) filter 410 the 1024 stored 1- 
bit results corresponding to the third row at a rate 
of one bit every two processor cycles. 

During the "Row 1" time period, (2x4) filter 406 
is inactive. During the "Row 2" time period, filter 
406 receives, in every two processor cycles, a 1 -bit 
result corresponding to the first row from buffer 



404 and a 1-bit result corresponding to the second 
row from filter 402. These two 1-bit results cor- 
respond to a (2x4) pixel area in the first and sec- 
ond rows of the 4-row pixel area of the selected 
5 thresholded image. Filter 406 performs an "AND" 
operation on the two 1-bit results, and transmits to 
(2x4) buffer 408 a 1-bit result corresponding to the 
first and second rows of the 4-row pixel area at a 
rate of 1 bit every two processor cycles. During the 

w "Row 3" and "Row 4" time periods, filter 406 is 
again inactive. 

During the "Row 1" time period, (2x4) buffer 
408 is inactive. During the "Row 2" time period, 
buffer 408 receives 1-bit results corresponding to 

is the first and second rows of the 4-row pixel area 
from filter 406. Since each 1-bit result from filter 
406 corresponds to a (2x4) pixel area in the first 
and second rows of the (4x4096) 4-row pixel area, 
buffer 408 stores 1024 1-bit results. During the 

20 "Row 3" time period, buffer 408 is again inactive. 
During the "Row 4" time period, buffer 408 trans- 
mits to (4x4) filter 410 the 1-bit results correspond- 
ing to the first and second rows at a rate of one bit 
every two processor cycles. 

25 During the "Row 1," "Row 2," and "Row 3" 

time periods, (4x4) filter 410 is inactive. During the 
"Row 4" time period, filter 410 receives, in every 
two processor cycles, a 1-bit result corresponding 
to the first and second rows from buffer 408, a 1 -bit 

30 result corresponding to the third row from buffer 
404, and a 1-bit result corresponding to the fourth 
row from filter 402. These three 1-bit results cor- 
respond to a (4x4) pixel area in the 4-row pixel 
area. Filter 410 performs an "AND" operation on 

35 the three 1-bit results, and transmits to (1x2) filter 
412 a 1-bit result corresponding to the four rows of 
the 4-row pixel area at a rate of 1 bit every two 
processor cycles. 

Each 1-bit result generated by filter 410 cor- 

40 responds to a non-overlapping (4x4) pixel area in a 
(4x4096) 4-row pixel area of the selected threshol- 
ded image. Filters 402, 406, and 410 and buffers 
404 and 408 repeat this processing for each 
(4x4096) 4-row pixel area of the selected threshol- 
ds ded image. As such, filters 402, 406, and 410 and 
buffers 404 and 408 implement a (4x4) MIN com- 
pression filter that effectively compresses the 
(2048x4096) selected thresholded image to a 
(512x1024) first compressed image. 

50 Fig. 6 presents a timing table showing the 
processing activities performed by filters 412 and 
416 and buffer 414 of circuit 400, which implement 
a (2x2) MIN compression filter on the (512x1024) 
first compressed image. Each row of the 

55 (512x1024) first compressed image represents four 
rows of the (2048x4096) selected thresholded im- 
age. For example, the first row of the first com- 
pressed image represents the first, second, third, 
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and fourth rows of the selected thresholded image. 
The second row of the first compressed image 
represents the fifth, sixth, seventh, and eighth rows 
of the selected thresholded image. 

The time periods in Fig. 6 correspond to the 
time periods during which the specified rows of an 
(8x4096) 8-row pixel area of a selected thresholded 
image is received by filter 402 from input buffer 
202. For example, the "Rows 1-3" time period 
corresponds to the time period during which the 
first three rows of the 8-row pixel area are received 
by filter 402 from input buffer 202. These time 
periods repeat for each successive (8x4096) 8-row 
pixel area of the selected thresholded image. 
Where each row comprises 4096 binary pixels and 
where two binary pixels are transmitted from input 
buffer 202 to filter 402 every processor cycle, a 
time period is equal to the number of correspond- 
ing rows times 2048 cycles. For example, the 
"Rows 5-7" time period corresponds to three rows 
of the selected thresholded image and is 6144 
processor cycles long. 

The (512x1024) first compressed image may 
be considered to comprise 256 (2x1024) 2-row 
pixel areas. During the "Row 4" time period, filters 
412 and 416 and buffer 414 process the first row of 
a (2x1024) 2-row pixel area of the first compressed 
image. Similarly, during the "Row 8" time period, 
filters 412 and 416 and buffer 414 process the 
second row of the (2x1024) 2-row pixel area. 

In every two processor cycles, (1x2) filter 412 
receives from filter 410 a binary pixel from the first 
compressed image. Filter 412 accumulates binary 
pixels for four processor cycles until two adjacent 
binary pixels are received. These two binary pixels 
correspond to a (1x2) pixel area in the first com- 
pressed image and represent a (4x8) pixel area in 
the selected thresholded image. Filter 412 then 
applies an "AND" function to the two binary pixels 
and transmits a 1-bit result every four processor 
cycles. During the "Rows 1-3" time period, filter 
412 is inactive. During the "Row 4" time period, 
filter 412 transmits 1-bit results corresponding to 
the first row of a (2x1024) 2-row pixel area of the 
first compressed image to (1x2) buffer 414. During 
the "Rows 5-7" time period, filter 412 is again 
inactive. During the "Row 8" time period, filter 412 
transmits 1-bit results corresponding to the second 
row of the (2x1024) 2-row pixel areas to (2x2) filter 
416. 

During the "Rows 1-3" time period, (1x2) buffer 
414 is inactive. During the "Row 4" time period, 
(1x2) buffer 414 receives 1-bit results correspond- 
ing to the first row of a (2x1024) 2-row pixel area of 
the first compressed image from filter 412. Since 
each 1-bit result from filter 412 corresponds to two 
adjacent binary pixels in a row of the (512x1024) 
first compressed image, buffer 414 stores 512 1-bit 



results. During the "Rows 5-7" time period, buffer 
414 is again inactive. During the "Row 8" time 
period, buffer 414 transmits the 1-bit results cor- 
responding to the first row of the (2x1024) 2-row 
5 pixel area to (2x2) filter 416 at a rate of one bit 
every four processor cycles. 

During the "Rows 1-7" time period, (2x2) filter 
416 is inactive. During the "Row 8" time period, 
filter 416 receives, in every four processor cycles, 
w a 1-bit result corresponding to the first row of a 
(2x1024) 2-row pixel area of the first compressed 
image from buffer 414 and a 1-bit result corre- 
sponding to the second row of the (2x1024) 2-row 
pixel area image from filter 412. These two 1-bit 
75 results correspond to a (2x2) pixel area in the first 
compressed image. Filter 416 performs an "AND" 
operation on the two 1-bit results, and transmits 1- 
bit results corresponding to the (2x1024) 2-row 
pixel area to (1x2) filter 418 at a rate of one bit 
20 every four processor cycles. 

Each 1-bit result generated by filter 416 cor- 
responds to a non-overlapping (2x2) pixel area in 
the (512x1024) first compressed image and repre- 
sents an (8x8) pixel area in the (2048x4096) se- 
25 lected thresholded image. Filters 412 and 416 and 
buffer 414 repeat this processing for each (2x1024) 
2-row pixel area of the first compressed image. As 
such, filters 412 and 416 and buffer 414 implement 
a (2x2) MIN compression filter that effectively com- 
30 presses the (512x1024) first compressed image to 
a (256x512) second compressed image. 

Fig. 7 presents a timing table showing the 
processing activities performed by filters 418 and 
422 and buffer 420, which implement a (2x2) MIN 
35 compression filter on the (256x512) second com- 
pressed image. (1x2) filter 418, (1x2) buffer 420, 
and (2x2) filter 422 operate analogously to filter 
412, buffer 414, and filter 416, respectively. Since 
each row of the second compressed image repre- 
40 sents eight rows of the selected thresholded image, 
filters 418 and 422 and buffer 420 process one row 
of the second compressed image for every eight 
rows received by filter 402 from input buffer 202. 
Because each row of the second compressed im- 
45 age has 512 binary pixels, buffer 420 stores 256 1- 
bit results from filter 418. Filters 418 and 422 and 
buffer 420 effectively compress the (256x512) sec- 
ond compressed image to a (128x256) third com- 
pressed image. Filter 422 transmits the binary pix- 
so els corresponding to the third compressed image 
to both (1x2) filter 424 and compression selection 
multiplexer 430 at a rate of one binary pixel every 
eight processor cycles. 

Fig. 8 presents a timing table showing the 
55 processing activities performed by filters 424 and 
428 and buffer 426, which implement a (2x2) MAX 
compression filter on the (128x256) third com- 
pressed image. (1x2) filter 424, (1x2) buffer 426, 
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and (2x2) filter 428 operate similarly to filter 412, 
buffer 414, and filter 416, respectively. However, 
since filters 424 and 428 and buffer 426 implement 
a MAX filter, filters 424 and 428 apply "OR" func- 
tions to their respective inputs. Since each row of 5 
the third compressed image represents sixteen 
rows of the selected thresholded image, filters 424 
and 428 and buffer 426 process one row of the 
third compressed image for every sixteen rows 
received by filter 402 from input buffer 202. Be- w 
cause each row of the third compressed image has 
256 binary pixels, buffer 426 stores 128 1-bit re- 
sults from filter 424. Filters 424 and 428 and buffer 
426 effectively compress the (128x256) third com- 
pressed image to a (64x128) fourth compressed js 
image. Filter 428 transmits the binary pixels cor- 
responding to the fourth compressed image to 
compression selection multiplexer 430 at a rate of 
one binary pixel every sixteen processor cycles. 

If the fourth compression filter performed by 20 
filters 424 and 428 and buffer 426 is activated, then 
compression selection multiplexer 430 transmits 
the binary pixels from filter 428 corresponding to 
the (64x128) fourth compressed image to output 
buffer 212 of VICKey card 106. Otherwise, mul- 25 
tiplexer 430 transmits the binary pixels from filter 
422 corresponding to the (128x256) third com- 
pressed image to output buffer 212. The fourth 
compression filter is preferably activated. The bi- 
nary pixels transmitted by multiplexer 430 to output 30 
buffer 212 correspond to the final compressed im- 
age. 

In this preferred embodiment of VICKey card 
106, working memory 210 requires 2944 memory 
cells to process a thresholded image having 4096 35 
binary pixels per row. The 2944 memory cells 
correspond to the sum of the 1024 1-bit results 
stored in buffer 404, the 1024 1-bit results stored in 
buffer 408, the 512 1-bit results stored in buffer 
414, the 256 1-bit results stored in buffer 420, and 40 
the 128 1-bit results stored in buffer 426. This 
preferred embodiment can process input images of 
any height and width, provided the numbers of 
pixel rows and columns are integer multiples of 32. 

Those skilled in the art will understand that 45 
where successive filter stages perform the same 
function, further memory reductions may be 
achieved. For example, since the (4x4) compres- 
sion filter and the first two (2x2) compression filters 
are all preferably MIN filters, an alternative embodi- 50 
ment could implement these three filters as one 
(16x16) MIN filter that could provide additional re- 
ductions in memory usage. The preferred embodi- 
ment described above balances the advantage of 
reduced memory usage against the advantages of 55 
providing a flexible system that may be used to 
implement different sequences of MIN and MAX 
compression filters. It will also be understood that 



other filtering schemes employing filters other than 
MIN and MAX filters may require additional mem- 
ory than the embodiment described in detail above. 

Exemplary Sequence of Compression Filters 

Figs. 9 through 14 present pixel images dem- 
onstrating the application of a preferred sequence 
of compression filters implemented by VICKey 
card 106 of location system 100. Fig. 9 presents an 
input image containing a barcode symbol. Fig. 9 is 
a (512x512) 8-bit gray-scale input image, where 
each 8-bit pixel is represented by an intensity level 
from 0 to 255. 

Fig. 10 presents a selected thresholded image 
that results from thresholding the input image of 
Fig. 9 at an intensity level of 70. Every 8-bit pixel in 
the input image of Fig. 9 that has an intensity level 
of 70 or lower is represented as a black binary 
pixel in the selected thresholded image of Fig. 10 
corresponding to the value "0". All other 8-bit pix- 
els in Fig. 9 having an intensity level greater than 
70 are represented in the selected thresholded 
image of Fig. 10 as white binary pixels correspond- 
ing to the value "1". Thus, the selected threshol- 
ded image of Fig. 10 is a (512x512) binary image. 

Fig. 1 1 presents a first compressed image that 
results from applying a (4x4) MIN compression 
filter, such as filter 304 of Fig. 3, to the selected 
thresholded image of Fig. 10. The first compressed 
image is a (128x128) binary image. Each binary 
pixel in the first compressed image of Fig. 11 
represents a (4x4) pixel area in the selected 
thresholded image of Fig. 10. 

Fig. 12 presents a second compressed image 
that results from applying a (2x2) MIN compression 
filter, such as filter 308 of Fig. 3, to the first 
compressed image of Fig. 11. The second com- 
pressed image is a (64x64) binary image. Each 
binary pixel in the second compressed image of 
Fig. 12 represents a (2x2) pixel area in the first 
compressed image of Fig. 1 1 . 

Fig. 13 presents a third compressed image that 
results from applying a (2x2) MIN compression 
filter, such as filter 312 of Fig. 3, to the second 
compressed image of Fig. 12. The third com- 
pressed image is a (32x32) binary image. Each 
binary pixel in the third compressed image of Fig. 
13 represents a (2x2) pixel area in the second 
compressed image of Fig. 12. 

Fig. 14 presents a fourth compressed image 
that results from applying a (2x2) MAX filter, such 
as filter 316 of Fig. 3, to the third compressed 
image of Fig. 13. The fourth compressed image of 
Fig. 14 is a (16x16) binary image. Each binary pixel 
in the fourth compressed image of Fig. 14 repre- 
sents a (2x2) pixel area in the third compressed 
image of Fig. 13. The binary pixels of the (16x16) 
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fourth compressed image of Fig. 14 are preferably 
transmitted by VICKey card 106 to processor 108. 

Location of Artifacts in Compressed Image 

Processor 108 of location system 100 receives 
from VICKey card 106 the binary pixels of a final 
compressed image that corresponds to the input 
image. If the fourth compression filter is activated, 
then the final compressed image is selected to be 
the fourth compressed image; otherwise, the final 
compressed image is selected to be the third com- 
pressed image. Processor 108 analyzes the final 
compressed image to locate regions that corre- 
spond to candidate barcode symbols in the input 
image. This analysis comprises searching through 
the final compressed image for isolated, contiguous 
black regions of proper geometry. The locations of 
these black regions in the final compressed image 
are used to select sub-images in the input image 
that may contain barcode symbols. Coordinates for 
these sub-images are then transmitted by proces- 
sor 108 to processor 110, which searches those 
sub-images for barcode symbols and, if found, 
decodes them. 

Fig. 15 presents a process flow diagram of 
sub-image identification subsystem 1500 of proces- 
sor 108 for identifying sub-images in the input 
image that may contain barcode symbols. In a 
preferred pipeline embodiment, sub-image iden- 
tification subsystem 1500 processes each row of 
the final compressed image as it is received from 
VICKey card 106. In this embodiment, identification 
subsystem 1500 supports operation of location sys- 
tem 100 in a continuous mode of operation in 
which a sequence of images is processed as one 
continuous image. 

In analyzing a final compressed image, iden- 
tification subsystem 1500 represents isolated, con- 
tiguous black regions in the final compressed im- 
age using elements, element lists, and a list of 
regions. An element is a set of one or more contig- 
uous black pixels in a row of the final compressed 
image. For example, an element comprises only 
one black pixel if that pixel has white pixels to the 
left and right. An element comprises two black 
pixels if each of two black pixels is adjacent to the 
other and also adjacent to a white pixel. Each row 
of a final compressed image may comprise zero, 
one, or more elements. 

A region defines an isolated, contiguous black 
region in the final compressed image. An element 
list is a list of elements from one or more different 
rows in the final compressed image that form a 
region. In a preferred embodiment based on four- 
way connectivity, a first element in one row of the 
final compressed image is "connected" to a sec- 
ond element in the next row if at least one binary 



pixel of the first element shares a side with a 
binary pixel of the second element. Each element 
in an element list of a region is connected to at 
least one other element in that region's element 
s list. At a particular point in the processing of a final 
compressed image, there may be zero, one, or 
more regions in the region list representing iso- 
lated, contiguous regions in the final compressed 
image. 

10 Means 1502 of identification subsystem 1500 
receives a new row of binary pixels from the final 
compressed image generated by VICKey card 106. 
Means 1504 generates the elements for the new 
row. Means 1506 updates the set of regions in the 

75 region list by comparing the elements in the new 
row with the elements in the element list of each 
region in the region list. If an element in the new 
row is connected to an element in the element list 
of a given region, then the element in the new row 

20 is added to the element list for that region. If an 
element in the new row is connected to two or 
more elements in the element lists of separate 
regions, then the two or more regions correspond- 
ing to those two or more elements are merged into 

25 one new region whose element list contains all the 
elements in those two or more regions plus the 
element in the new row. If an element in the new 
row is not connected to any of the elements in any 
of the element lists, then a new region is added to 

30 the region list containing in its element list only the 
element in the new row. 

Means 1508 deletes from the region list those 
regions that are too big. In applications where 
location system 100 finds barcode symbols of 

35 known minimum and maximum dimensions and 
areas, barcode symbols in input images are repre- 
sented in final compressed images by isolated, 
contiguous black regions with areas falling between 
known minimum and maximum areas. In these 

40 applications, identification subsystem 1500 may ig- 
nore black regions in the final compressed image 
that are too big or too small. These black regions 
may represent areas in the input images other than 
barcode symbols. In alternative applications in 

45 which other symbologies are being located, the 
minimum and maximum dimensions and areas 
may be different. 

Means 1508 tests the size of each black region 
of the final compressed image currently repre- 

50 sented by the region list against a specified maxi- 
mum threshold that may represent the largest bar- 
code symbol expected in the input images. The 
size of a black region is the total number of black 
pixels in all of the elements in the element list 

55 corresponding to the black region. If the size of a 
black region exceeds the specified maximum 
threshold, means 1508 deletes that region from the 
current region list. 

12 
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Means 1510 selects those regions that are 
completed. A region is completed if none of the 
elements in a region's element list is connected to 
any element in the new row of the final com- 
pressed image. The element list for a completed 
region comprises all the elements that correspond 
to an isolated, contiguous region in the final com- 
pressed image. 

Means 1512 analyzes the completed regions 
identified by means 1510 against specified geome- 
try requirements. As described earlier in this sec- 
tion in conjunction with means 1508, isolated, con- 
tiguous black regions in the final compressed im- 
age that are too big or too small may be rejected 
as not representing candidate barcode symbols. 
Since means 1508 has already ensured that com- 
pleted regions are not too big, means 1512 may 
test the size of each completed region against a 
specified minimum threshold representing the size 
of the smallest barcode symbol expected in the 
input images. If the size of a completed region is 
less than the minimum threshold, then the com- 
pleted region is rejected by means 1512. In alter- 
native preferred embodiments, means 1512 may 
implement alternative geometry tests including, for 
example, testing the ratio of major and minor axes 
of each completed region against specified thresh- 
olds, where the axes are determined by performing 
conventional statistical analyses on the completed 
region. 

Any completed region in the final compressed 
image that satisfies the geometry requirements of 
means 1512 is considered to represent a candidate 
barcode symbol in the input image. Means 1514 
maps each completed region selected by means 
1510 back to the input image to determine the 
coordinates of a sub-image in the input image that 
contains the candidate barcode symbol. This map- 
ping is described in further detail later in this 
section in conjunction with the example of Fig. 14. 
Each sub-image in the input image may be unique- 
ly designated by the two rows and two columns 
that form the outer boundary of the sub-image. 
Means 1516 then transmits the boundary data for 
each sub-image in the input image containing a 
candidate barcode symbol to processor 110 for 
barcode symbol identification and decoding. The 
boundary data defines the two-dimensional gray- 
scale pixel image received as input by the barcode 
symbol detecting and decoding systems described 
in the three U.S. patent applications filed August 
10, 1992 referred to earlier in this specification in 
conjunction with Fig. 1 . 

Those skilled in the art will understand that 
when location system 100 is operated in a continu- 
ous mode in which a series of input images are 
processed as one continuous image, barcode sym- 
bols that fall partially within the "bottom" of one 



input image and partially within the "top" of the 
next input image may successfully be processed 
by location system 100. This may be achieved with 
either the snapshot, partial snapshot, or pipeline 

5 embodiments. 

The operations of identification subsystem 
1500 may further be illustrated in the context of the 
particular example of the fourth and final com- 
pressed image of Fig. 14. When processing of 

io identification subsystem 1500 begins, no rows of 
the final compressed image have yet been pro- 
cessed and there are no regions. Means 1502 first 
receives the binary pixels from row 1 of the final 
compressed image of Fig. 14. Since all of these 

75 binary pixels are white, there are no elements in 
row 1 and means 1504 generates no elements for 
row 1. Since there are no regions yet, processing 
flows from means 1506 through means 1516 and 
returns to means 1502 to receive the next row of 

20 the final compressed image. The same is true for 
rows 2, 3, and 4, which also contain only white 
pixels. 

After means 1502 receives row 5, means 1504 
generates element 1404 for row 5, where element 

25 1404 comprises pixels (9,5), (10,5), and (11,5). 
Since there are no regions in the region list, means 
1506 enters new region 1402 in the region list, 
where the element list for region 1402 contains 
element 1404. Means 1508 compares the size of 

30 region 1402 to the specified maximum threshold to 
determine whether region 1402 is too big. At this 
point in the processing, region 1402 has an area of 
three pixels. A typical specified maximum threshold 
for a barcode symbol may be approximately 50 

35 pixels. As such, means 1508 determines that re- 
gion 1402 is not too big. Means 1510 then deter- 
mines whether region 1402 is completed. Since 
element 1404 forms part of region 1402, region 
1402 is not completed. Processing then continues 

40 from means 1512 through means 1516 and returns 
to means 1502. 

After means 1502 receives row 6, means 1504 
generates element 1406 for row 6, where element 
1406 comprises pixels (9,6), (10,6), and (11,6). 

45 After means 1506 determines that element 1406 of 
row 6 is connected to element 1404 of row 5, 
means 1506 updates the element list for region 
1402 by adding element 1406 to the element list 
for region 1402. Means 1508 determines that the 

so current area of region 1402 of 6 pixels is still less 
than the specified maximum threshold of 50 pixels. 
Since element 1406 forms part of region 1402, 
means 1510 determines that region 1402 is not 
completed, and processing continues through 

55 means 1516 and returns to means 1502. 

Identification subsystem 1500 continues to pro- 
cess rows 7 through 11 of the final compressed 
image of Fig. 14 in similar fashion, adding ele- 
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ments 1408 through 1416 to the element list for 
region 1402. After means 1502 receives row 12, 
means 1504 generates elements 1418, 1420, and 
1422 for row 12, where element 1418 comprises 
pixel (3,12), element 1420 comprises pixels (5,12), 
(6,12). and (7,12), and element 1422 comprises 
pixel (10,12). Means 1506 adds regions 1424 and 
1426 to the region list, where the element list for 
region 1424 contains element 1418 and the ele- 
ment list for region 1426 contains element 1422. 
Means 1506 also adds element 1420 to the ele- 
ment list for region 1402. 

Means 1504 generates elements 1428 and 
1430 for row 13. Means 1506 adds element 1428 
to the element list for region 1402 and adds new 
region 1432 containing element 1430 to the region 
list. Element 1430 in row 12 is not connected to 
element 1422 in row 13, because they have only a 
common corner and not a common side. At this 
point, there are four regions in the region list repre- 
senting regions 1402, 1424, 1426, and 1432. Since 
the largest region is region 1402 with 26 pixels, 
means 1508 determines that none of these four 
regions is too big. Means 1510 then determines 
that regions 1424 and 1426 are completed because 
they are not connected to any elements of row 1 3. 

Means 1512 determines whether each of com- . 
pleted regions 1424 and 1426 is too small by 
comparing the area of each region to a specified 
minimum threshold. A typical specified minimum 
threshold for a barcode symbol may be approxi- 
mately 15 pixels. Since both completed regions 
1424 and 1426 have an area of 1 pixel, means 
1512 rejects completed regions 1424 and 1426 as 
not corresponding to candidate barcode symbols. 
Completed regions 1424 and 1426 may then be 
deleted from the region list. 

For row 14, means 1504 generates element 
1434. Means 1506 adds new region 1436 contain- 
ing element 1434 to the region list. Means 1508 
determines that regions 1402, 1432, and 1436 are 
not too big. Means 1510 then determines that re- 
gions 1402 and 1432 are completed, since they are 
not connected to any element of row 14. Means 
1512 rejects completed region 1432 as too small, 
but selects completed region 1402 as representing 
a candidate barcode symbol, because region 1402 
satisfies the specified geometry requirements. 

Means 1514 then maps selected completed 
region 1402 to a sub-image in the input image of 
Fig. 9 from which the final compression image of 
Fig. 14 was generated. Means 1514 analyzes the 
element list for region 1402 to identify the top and 
bottom rows and the left and right columns of 
region 1402. Region 1402 has top row 5, bottom 
row 13, left column 5, and right column 11. Means 
1514 maps these rows and columns back to the 
input image by reversing the compression ratio. In 



the example of Figs. 9 through 14, all four com- 
pression filters are activated and the compression 
ratio for both rows and columns is 32. Thus, row 1 
of the final compressed image of Fig. 14 repre- 

5 sents rows 1 through 32 of the input image of Fig. 
9, row 2 represents rows 33 through 64, etc. 

The top row of a region may be mapped back 
to the input image by multiplying the row number 
in the final compressed image by the compression 

w ratio n (for Fig. 14, r? = 32) and subtracting (n- /) 
from the result. An equivalent equation may be 
used to map the left column of a region to the input 
image. When mapping the bottom row or right 
column of a region back to the input image, the 

75 row or column number in the final compressed 
image is multiplied by n and then an additional (n- 
1) pixels is added to the result. In the final com- 
pressed image of Fig. 14, top row 5 of region 1402 
is mapped back to input row 129 in the input image 

20 of Fig. 9; bottom row 13, to input row 497; left 
column 5, to input column 129; and right column 
1 1 , to input column 383. 

The resulting two rows and two columns define 
the sub-image of the input image that corresponds 

25 to region 1402 in the final compressed image. In a 
preferred embodiment, the borders of this sub- 
image may be further expanded by fixed numbers 
of pixels in each direction to ensure that the sub- 
image contains the entire candidate barcode sym- 

30 bol. The degree to which the borders of the sub- 
image in the input image are expanded may be 
determined experimentally to ensure complete en- 
closure of the area of interest within the sub-image 
borders. The two rows and two columns for each 

35 region are then transmitted by means 1516 to 
processor 110 for barcode symbol identification 
and decoding. 

Processing then returns to means 1502 to re- 
ceive row 15. Means 1504 generates elements 

40 1438 and 1440 for row 15. Means 1506 adds new 
region 1442 containing element 1438 to the region 
list and adds element 1440 to the element list for 
region 1436. When row 16 is processed, means 
1510 determines that regions 1442 and 1436 are 

45 completed, but then means 1512 rejects these two 
completed regions as being too small to represent 
candidate barcode symbols and deletes them from 
the region list. 

Thus, in the example of the final compressed 

so image of Fig. 14, identification subsystem 1500 
generated six regions corresponding to regions 
1402, 1424, 1426, 1432, 1436, and 1442, only 
region 1402 of which was selected as satisfying the 
specified geometry requirements for candidate bar- 

55 code symbols. Region 1402 represents the bar- 
code symbol contained in the input image of Fig. 9. 
Therefore, location system 100 filtered the input 
image with a sequence of thresholding and com- 

14 
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pression filters, and analyzed the resulting final 
compressed image to identify successfully a sub- 
image containing the one and only barcode symbol 
in the input image. 

An alternative embodiment of the present in- s 
vention is based on 8-way connectivity in which a 
black pixel is said to be connected to another black 
pixel if they share at least a common corner. In this 
embodiment, identification system 1500 would con- 
sider regions 1426 and 1432 of Fig. 14 to be a 10 
single isolated, contiguous black region. 

It will be understood by those skilled in the art 
that various elements of the system of the present 
invention may be implemented in either hardware 
or software and/or by either serial or parallel pro- 75 
cessing. It will be further understood that various 
changes in the details, materials, and arrangements 
of the parts which have been described and illus- 
trated in order to explain the nature of this inven- 
tion may be made by those skilled in the art 20 
without departing from the principle and scope of 
the invention as expressed in the following claims. 

Claims 

25 

1. A method for finding an area of interest in an 
input image, comprising the steps of: 

(a) filtering said input image with at least 
one compression filter (208) to generate a 

final compressed image; 30 

(b) determining the location of an artifact in 
said final compressed image; and 

(c) determining the location of said area of 
interest in said input image according to 

said location of said artifact in said final 35 
compressed image. 

2. The method of claim 1, wherein said area of 
interest comprises a barcode symbol. 

40 

3. The method of claim 1, wherein said input 
image comprises a two-dimensional gray-scale 
pixel image generated with a CCD camera 
(102). 

45 

4. The method of claim 1 , wherein step (a) com- 
prises the steps of: 

(1) thresholding said input image with a 
thresholding filter to generate a thresholded 
image; and 50 

(2) compressing said thresholded image 
with at least one compression filter (300) to 
generate said final compressed image. 

5. The method of claim 4, wherein step (a)(1) 55 
comprises the step of thresholding said input 
image with an adaptive thresholding filter to 
generate said thresholded image. 



6. The method of claim 4, wherein step (a)(2) 
comprises the steps of: 

(i) compressing said thresholded image with 
a (4x4) compression filter (304) to generate 
a first compressed image; 

(ii) compressing said first compressed im- 
age with a first (2x2) compression filter 
(308) to generate a second compressed im- 
age; and 

(iii) compressing said second compressed 
image with a second (2x2) compression fil- 
ter (312) to generate a third compressed 
image, wherein said third compressed im- 
age is selected to be said final compressed 
image. 

7. The method of claim 6, wherein step (a)(2) 
further comprises the step of: 

(iv) compressing said third compressed im- 
age with a third (2x2) compression filter 
(316) to generate said final compressed im- 
age, wherein said (4x4) compression filter 
(304) and said first and second (2x2) com- 
pression filters (308, 312) are all MIN com- 
pression filters and said third (2x2) com- 
pression filter (316) is a MAX compression 
filter. 

8. The method of claim 1 , wherein step (a) com- 
prises the steps of: 

(1) receiving a first row of said input image; 

(2) applying at least one two-dimensional 
compression filter to said first row to begin 
generating said final compressed image; 

(3) receiving a second row of said input 
image, wherein step (a)(2) begins before 
step (a)(3) begins; and 

(4) applying said at least one two-dimen- 
sional compression filter to said second row 
to continue generating said final com- 
pressed image. 

9. The method of claim 1, wherein said final 
compressed image comprises a plurality of 
rows of binary pixels, step (b) comprises the 
steps of: 

(1) receiving a row of said final compressed 
image; 

(2) determining which pixels of said row 
correspond to a black region in said final 
compressed image; 

(3) saving said pixels corresponding to said 
black region in a list for said black region; 

(4) determining if said list is complete; 

(5) if said list is complete, then determining 
whether said black region satisfies specified 
geometry requirements; 
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(6) if said black region satisfies said speci- 
fied geometry requirements, then selecting 
said black region as said artifact in said final 
compressed image; 

(7) selecting top and bottom rows and left 5 
and right columns corresponding to said 
location of said artifact; 

(8) repeating steps (b)(1) through (b)(7) for 
each row of said final compressed image, 

and wherein step (c) comprises the step of 10 
mapping said selected top and bottom rows 
and left and right columns from said final com- 
pressed image to identify said location of said 
area of interest in said input image. 

75 

10. The method of claim 1, wherein said input 
image is a two-dimensional input image and 
step (a) comprises the steps of: 

(1) receiving a first row of said input image; 

(2) applying said at least one two-dimen- 20 
sional compression filter to said first row to 
begin generating said final compressed im- 
age; 

(3) receiving a second row of said input 
image, wherein step (a)(2) begins before 25 
step (a)(3) begins; and 

(4) applying said at least one two-dimen- 
sional compression filter to said second row 
to continue generating said final com- 
pressed image. 30 

11. The method of claim 10, wherein step (a)(2) 
begins before step (a)(1) is completed. 

12. The method of claim 10, wherein step (a)(4) 35 
begins before step (a)(3) is completed. 

13. An apparatus for finding an area of interest in 
an input image, comprising: 

(a) filtering means (208) for filtering said 40 
input image with at least one compression 
filter to generate a final compressed image; 

(b) first determining means (109) for deter- 
mining the location of an artifact in said final 
compressed image; and 45 

(c) second determining means for determin- 
ing the location of said area of interest in 
said input image according to said location 
of said artifact in said final compressed im- 
age, so 

14. The apparatus of claim 13, wherein said area 
of interest comprises a barcode symbol. 

15. The apparatus of claim 13, wherein said input 55 
image comprises a two-dimensional gray-scale 
pixel image generated with a CCD camera 
102). 



16. The apparatus of claim 13, wherein said filter- 
ing means comprises: 

(1) thresholding means for thresholding said 
input image with a thresholding filter to gen- 
erate a thresholded image; and 

(2) compressing means (208) for compress- 
ing said thresholded image with at least one 
compression filter to generate said final 
compressed image. 

17. The apparatus of claim 16, wherein said 
thresholding means comprises means for 
thresholding said input image with an adaptive 
thresholding filter to generate said thresholded 
image. 

18. The apparatus of claim 16, wherein said com- 
pressing means (208) comprises: 

(i) means for compressing said thresholded 
image with a (4x4) compression filter (304) 
to generate a first compressed image; 

(ii) means for compressing said first com- 
pressed image with a first (2x2) compres- 
sion filter 308) to generate a second com- 
pressed image; and 

(iii) means for compressing said second 
compressed image with a second (2x2) 
compression filter (312) to generate a third 
compressed image, wherein said third com- 
pressed image is selected to be said final 
compressed image. 

19. The apparatus of claim 18, wherein said com- 
pressing means (208) further comprises: 

(iv) means for compressing said third com- 
pressed image with a third (2x2) compres- 
sion filter (316) to generate said final com- 
pressed image, wherein said (4x4) com- 
pression filter (304) and said first (308) and 
second (2x2) compression filters (312) are 
all MIN compression filters and said third 
(2x2) compression filter (316) is a MAX 
compression filter. 

20. The apparatus of claim 13, wherein said filter- 
ing means comprises: 

(1) means for receiving a first row of said 
input image; 

(2) means for applying at least one two- 
dimensional compression filter to said first 
row to begin generating said final com- 
pressed image; 

(3) means for receiving a second row of 
said input image; and 

(4) means for applying said at least one 
two-dimensional compression filter to said 
second row to continue generating said final 
compressed image. 
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21. The apparatus of claim 13, wherein said final 
compressed image comprises a plurality of 
rows of binary pixels, said first determining 
means comprises: 

(1) means for receiving a row of said final 
compressed image; 

(2) means for determining which pixels of 
said row correspond to a black region in 
said final compressed image; 

(3) means for saving said pixels corre- 
sponding to said black region in a list for 
said black region; 

(4) means for determining if said list is 
complete; 

(5) means for determining whether said 
black region satisfies specified geometry re- 
quirements, if said list is complete; 

(6) means for selecting said black region as 
said artifact in said final compressed image, 
if said black region satisfies said specified 
geometry requirements; 

(7) means for selecting top and bottom rows 
and left and right columns corresponding to 
said location of said artifact, 

and wherein said second determining 
means comprises means for mapping said se- 
lected top and bottom rows and left and right 
columns from said final compressed image to 
identify said location of said area of interest in 
said input image. 

22. The apparatus of claim 13, wherein said input 
image is a two-dimensional input image and 
said filtering means comprises: 

(1) means for receiving a first row of said 
input image; 

(2) means for applying said at least one 
two-dimensional compression filter to said 
first row to begin generating said final com- 
pressed image; 

(3) means for receiving a second row of 
said input image; and 

(4) means applying said at least one two- 
dimensional compression filter to said sec- 
ond row to continue generating said final 
compressed image. 

23. A method for finding one or more artifacts in a 
two-dimensional image, comprising the steps 
of: 

(a) receiving a first row of said image; 

(b) generating a list of regions in accor- 
dance with said first row; 

(c) receiving a next row of said image; 

(d) updating said list of regions in accor- 
dance with said next row; 

(e) determining whether a region in said list 
of regions corresponds to an artifact in said 



image; and 

(f) selecting said region as said artifact in 
accordance with the determination of step 
(e). 

5 

24. The method of claim 23, further comprising the 
step of repeating steps (c) through (f). 

25. The method of claim 23, wherein step (b) 
jo further comprises the step of generating a list 

of elements for said first row, step (d) further 
comprises the steps of: 

(1 ) generating a list of elements for said first 

row; and 

T5 (2) comparing said list of elements for said 

next row to said list of regions. 

26. The method of claim 25, wherein said compari- 
son of step (d)(2) further comprises the step of 

20 determining the connectivity between said list 

of elements for said next row and said list of 
regions. 

27. The method of claim 23, wherein said deter- 
25 mination of step (e) comprises the step of 

determining whether said region is complete. 

2a The method of claim 23, wherein said deter- 
mination of step (e) comprises the step of 
30 testing said region against specified geometry 

requirements. 

29. An apparatus for finding one or more artifacts 
in a two-dimensional image, comprising: 
35 (a) means for receiving a first row of said 

image; 

(b) generating means for generating a list of 
regions in accordance with said first row; 

(c) means for receiving a next row of said 
40 image; 

(d) updating means for updating said list of 
regions in accordance with said next row; 

(e) determining means for determining 
whether a region in said list of regions cor- 

45 responds to an artifact in said image; and 

(f) means for selecting said region as said 
artifact in accordance with the determination 
of said determining means. 

so 30. The apparatus of claim 29, wherein said gen- 
erating means comprises means for generating 
a list of elements for said first row, said updat- 
ing means comprises: 

(1) means for generating a list of elements 
55 for said first row; and 

(2) comparing means for comparing said list 
of elements for said next row to said list of 
regions. 
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31. The apparatus of claim 30, wherein said com- 
paring means comprises means for determin- 
ing the connectivity between said list of ele- 
ments for said next row and said list of re- 
gions, s 

32. The apparatus of claim 29, wherein said deter- 
mining means comprises means for determin- 
ing whether said region is complete. 

10 

33. The apparatus of claim 29, wherein said deter- 
mining means comprises means for testing 
said region against specified geometry require- 
ments. 

75 
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Fig. 5 [Sequence of Processing for (4x4) MIN Filter.] 



Time Period (1x4) filter 420 activity 



Row 1: 
Row 2: 
Row 3: 
Row 4: 



filter row 1, transmit row l 

filter row 2, transmit row 2 

filter row 3, transmit row 3 

filter row 4, transmit row 4 



results to buffer 404 

results to filter 406 

results to buffer 404 

results to filter 410 



Time Period (1x4) buffer 404 activity 

Row 1: receive and store row 1 results from filter 402 

Row 2: transmit row 1 results to filter 40 6 

Row 3: receive and store row 3 results from filter 402 

Row 4: transmit row 3 results to filter 410 



Time Period (2x4) filter 406 activity 



Row 1: 
Row 2: 



Row 3: 
Row 4 : 



inactive 

receive row 1 results from buffer 404, receive row 

2 results from filter 402, filter row 1-2 results, 

transmit row 1-2 results to buffer 408 

inactive 

inactive 



Time Period (2x4) buffer 408 activity 



Row 1: 
Row 2: 
Row 3: 
Row 4: 



inactive 

receive and store row 1-2 results from filter 406 
inactive 

transmit row 1-2 results to filter 410 



TjLme Period (4x4) filter 410 activity 



Row 1: 
Row 2: 
Row 3: 
Row 4: 



inactive 
inactive 
inactive 

receive row 1-2 results from buffer 408, receive 
row 3 results from buffer 404, receive row 4 
results from filter 402, filter row 1-4 results, 
transmit row 1-4 results to filter 412 
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Fig. 6 [Sequence of Processing for First (2x2) MIN Filter.] 



Time Period (iW) filter 412 activity 



Rows 1-3 : 
Row 4: 



Rows 5-7 : 
Row 8: 



inactive 

receive row 1-4 results from filter 410, filter 
row 1-4 results, transmit row 1-4 results to 
buffer 414 
inactive 

receive row 5-8 results from filter 410, filter 
row 5-8 results, transmit row 5-8 results to 
filter 416 



Time Period 



(1x2) buffer 414 activity 



Rows 1-3: inactive 

Row 4: receive and store row 1-4 results from filter 412 

Rows 5-7: inactive 

Row 8: transmit row 1-4 results to filter 416 



Time Period (2x2) filter 416 activity 
Rows 1-7: inactive 

Row 8: receive row 1-4 results from buffer 414, receive 

row 5-8 results from filter 412, filter row 1-8 
results, transmit row 1-8 results to filter 418 
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Time Period 

Rows 1-7: 
Row 8: 



Rows 9-15: 
Row 16: 



Time Period 

Rows 1-7: 
Row 8: 
Rows 9-15: 
Row 16: 



Time Period 

Rows 1-15: 
Row 16: 



ice of Processing for Second (2x2) MIN Filter.] 

(1x2) filter 418 activity 
inactive 



row 1-8 results, transmit row 1-8 results to 

buffer 420 

inactive 

receive row 9-16 results from filter 416, filter 
row 9-16 results, transmit row 9-16 results to 
filter 422 



(1x2) buffer 420 activity 
inactive 

receive and store row 1-8 results from filter 418 
inactive 

transmit row 1-8 results to filter 422 



(2x2) filter 422 activity 
inactive 

receive row 1-8 results from buffer 420, receive 
row 9-16 results from filter 422, filter row 1-16 
results, transmit row 1-16 results to filter 424 
and MUX 430 




25 



EP 0 584 559 A2 



Fig. 8 [Sequence of Processing for (2x2) MAX Filter.] 



yfcne Period (1x21 filter 424 activity 



Rows 1-15: 
Row 16: 



Rows 17-31: 
Row 32: 



inactive 

receive row 1-16 results from filter 422, filter 
row 1-16 results, transmit row 1-16 results to 
buffer 426 
inactive 

receive row 17-32 results "from filter 422, filter 
row 17-32 results, transmit row 17-32 results to 
filter 428 



Time Period 

Rows 1-15: 
Row 16: 
Rows 17-31: 
Row 32: 



(1x21 buffer 426 activity 
inactive 

receive and store row 1-16 results from filter 424 
inactive 

transmit row 1-16 results to filter 428 



Time Period 

Rows 1-31: 
Row 32: 



(2x2) filter 428 activity 
inactive 

receive row 1-16 results from buffer 426, receive 
row 17-32 results from filter 424, filter row 1-32 
results, transmit row 1-32 results to MUX 430 
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FIG. 15 [IDENTIFYING SUB-IMAGES CONTAINING CANDIDATE 
BARCODE SYMBOLS IN AN INPUT IMAGE.] 



1500 



1502- 



1504- 



1506- 



1508- 



1510 



1512 



1514- 



1516 



START 

i 



RECEIVE NEW ROW OF < 
FINAL COMPRESSED MAGE. 






GENERATE ELEMENTS 
FOR NEW ROW. 







UPDATE REGIONS 
BASED ON CONNECTIVITY 
BETWEEN ELEMENTS IN NEW ROW 
AND ELEMENTS IN PREVIOUS ROT. 



DELETE REGIONS 
THAT ARE TOO BIG. 



SELECT REGIONS 
THAT ARE COMPLETED. 



SELECT COMPLETED REGIONS THAT 
SATISFY GEOMETRY REQUIREMENTS 



MAP SELECTED COMPLETED 
REGIONS TO SUB-IMAGES 
IN INPUT IMAGE. 



TRANSMIT COORDINATES OF 
SUB-IMAGES IN INPUT IMAGE 
TO PROCESSOR lift. 
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